// 页面添加水印效果
const id = '1.23452384164.123412416';
const setWatermark = (str: string) => {
	if (document.getElementById(id) !== null) {
		document.body.removeChild(<HTMLElement>document.getElementById(id));
	}
	// 创建一个画布
	const can = document.createElement('canvas');
	// 设置画布长度
	can.width = 200;
	can.height = 130;
	// 旋转角度
	const cans: any = can.getContext('2d');
	cans.rotate((-20 * Math.PI) / 180);
	// 字体以及绘画的颜色、渐变
	cans.font = '12px Vedana';
	cans.fillStyle = 'rgba(200, 200, 200, 0.30)';
	//设置在绘制文本时使用的当前文本基线
	cans.textBaseline = 'Middle';
	//在画布上绘制填色的文本（输出的文本，开始绘制文本的X坐标位置，开始绘制文本的Y坐标位置）
	cans.fillText(str, can.width / 10, can.height / 2);

	// 渲染水印标签
	const div: HTMLDivElement = document.createElement('div');
	div.id = id;
	div.style.pointerEvents = 'none';
	div.style.top = '15px';
	div.style.left = '0px';
	div.style.position = 'fixed';
	div.style.zIndex = '9999';
	div.style.width = `${document.documentElement.clientWidth}px`;
	div.style.height = `${document.documentElement.clientHeight}px`;
	div.style.background = `url(${can.toDataURL('image/png')}) left top repeat`;
	document.body.appendChild(div);
};

const watermark = {
	// 设置水印
	set: (str: string) => {
		document.getElementById(id) === null && setWatermark(str);
	},
	// 删除水印
	del: () => {
		document.getElementById(id) !== null && document.body.removeChild(<HTMLElement>document.getElementById(id));
	},
};

export default watermark;
